草庐IT

database - 用户表 - redis 或 postgres

全部标签

go - Go中的二级缓存(内存+redis)实现

我正在尝试写一个二级缓存(内存+redis),但是当一个key高并发访问时遇到了瓶颈,我尝试对每个key都使用mutex,但是这样增加了cpu很多因为loadFromDB需要100-200毫秒。func(s*Store)GetJsonObjectWithExpire(keystring,objinterface{},ttlint,fStoreLoadFunc)error{//firstreadfrommemoryv,ok:=s.mem.Get(key)ifok{ifv.Outdated(){to:=deepcopy.Copy(obj)gos.updateMem(key,to,ttl,f

database - 测试数据库交互

我有一个具有存储层的API。它只进行数据库交互并执行CRUD操作。现在我想测试这些功能。在我的路径API/storage/中,我有不同的包,这些包具有与同一数据库中的不同表进行交互的功能。表A、B和C在同一个数据库中。我的文件层次结构如下:--api--storage--A--A.go--A_test.go--B--C--server--A--testData--A.sql--B.sql这样我想用命令测试整个存储层gotest./...我遵循的方法是我有一个函数RefreshTables,它首先截断表,然后用我保存在testData文件夹中的固定测试数据填充它。对于截断我这样做:db.

sql - 使用GoLang包“database/sql”时,是否可以使用通用类型变量检索查询结果

我上一个问题的推论:IsitpossibletoretrieveacolumnvaluebynameusingGoLangdatabase.sql:sql.Rows.scan()需要一个正确键入的变量,该变量正确放置在scan()调用中。这可能很乏味,并且还要求开发人员具有可用的db模式-并不总是可行的。我试图通过所有参数传递一个空的interface{}指针来使其工作。但这到目前为止还不能很好地解决,并且在访问值时还需要类型声明,这将很昂贵。有没有办法做到这一点? 最佳答案 在golang坚果邮件列表中,对此进行了更长的讨论。参见

go - 在 Telegram 机器人中保存菜单交互之间的用户状态

我正在创建一个贸易Telegram机器人,我想有大约5个不同的菜单(键盘)来与用户交流。第一步,我为用户提供了选择交易所进行交易的能力,之后她应该选择货币,然后选择价格,然后她可以看到另一个用户的订单等。从后端View来看,用户消息只是一个文本,我通过分析该文本(老式switch语句)来选择将请求路由到哪里。第一步没问题,我只有几个交易所,所以我知道用户在第一步,但是当她选择货币时,我怎么知道他在上一步选择了哪个交易所?当然,我可以使用数据库来保存所有用户菜单交互,但我感兴趣是否存在其他选择? 最佳答案 尝试使用InlineQuer

database - 在结构数组中搜索

我有一个这样定义的结构:typeIssuesstruct{RedmineIssuestringGitlabIssuestring}然后我从数据库中获取列表database.Find(&Issues)然后我有另一个数组redmineIssues[]redmine.Issue有没有什么方法可以在我的数组问题中搜索问题,这些问题也在基于字段RedmineIssue(字符串)的数组redmineIssues中?今天是我在做的事database.Find(&Issues)redmineIssue:=[]string{}for_,issueRedmine:=rangeIssues{redmineI

go - 我有一张用户表。我想编写一个 API 来使用 id 获取数据。我不断收到以下错误。请注意,数据库已经满了

我有一张用户表。我想编写一个API来使用id获取数据。我不断收到以下错误。请注意,数据库已经满了。我想创建一个获取api,我在其中传递id并作为结果获取该行。我已经尝试了一些事情,但我一直收到此错误。数据库架构-deadpool=#\duser_dataTable"public.user_data"Column|Type|Collation|Nullable|Default--------------------+--------------------------+-----------+----------+-------------------------------------

go - 遍历别名(用户定义)类型的 slice 在别名之前给出类型

我正在尝试遍历用户定义类型的slice(在下面的示例中,这些是别名int),但是range生成类型为int的值,而不是我期望的MyInt。在“if”内部进行强制转换肯定有帮助,但我想了解为什么范围不产生MyInt类型的值。packagemainimport("fmt")typeMyIntintconst(MYINT00MyInt=iotaMYINT01)funcmain(){varmyInt02MyInt=2myInts:=[]MyInt{MYINT00,MYINT01}fori:=rangemyInts{ifi==myInt02{fmt.Println("same")}}}Playg

postgresql - 使用 Golang 查询 Postgres

使用go查询时,我对从Postgres收到的输出感到有些困惑。因为我对此很陌生,所以我什至很难为我遇到的这个问题形成正确的问题,所以我将在这里留下一个代码块,以及我收到的输出和我期望发生的事情。我希望这能让它更容易理解。与postgres数据库的连接似乎工作正常rows,err:=db.Query("SELECTtitleFROMblogs;")fmt.Println("output",rows)但是,这是我收到的输出。output&{0xc4200ea1800x4c0e200xc42009a3c00x4b4f90{{00}0000}false[]}正如我所说,我是postgres的新

postgresql - 微服务使 postgres 连接倍增

我有一个通过golang编写的服务,它作为消费者工作,它从kafka的队列中获取数据并将其存储在PostgreSQL数据库中。在执行某些请求时,golang开始增加PG连接,然后超过它们的限制。我不知道为什么,请帮我解决这个问题。这是代码:funcSaveMessageStatus(msgmodels.Message)error{db:=GetPostgreInstance()//Get*sql.DBinstance//Проверяеместьлизаписиrows,err:=db.Query(`select*from"tNotifStatus"where"Notification

Golang - 没有选择器的包的用户

拜托,我搜索了很多,在找不到之后,我正在写,而不是我没有先尝试搜索。无法得到正确答案。我什至试图检查Revel的功能,但也无法从那里得到答案。当我运行这个程序时,我得到了一行的错误./test.go:11:useofpackagehttpwithoutselector这个错误指向下面我写的那一行*http结构内部令人困惑的是,使用test和dot我什至可以使用VIM自动完成。所以我不知道为什么会出错。是不是一定要有点像*(net/http)或类似的东西?packagemainimport("fmt""net/http")typeHandleHTTPstruct{*http}funcha